**CS2100 Assignment 2 Answer Book**

|  |  |
| --- | --- |
| **Name:** | Neo Haowei |
| **Student ID:** | A0264683U |
| **Tutorial Group Number:** | 41 |

After completion, save this file as AxxxxxxxY.pdf and submit on Canvas together with your code as per the instructions given in the question paper.

If you do not fill your particulars above, or do not follow the submission instructions you will forfeit up to 3 marks.

Submission information: \_\_\_\_\_\_\_\_\_\_\_\_\_\_ / 3

**Part A**

**Question 1.** (7 MARKS)

(Use the space to describe the working/thinking behind your code. Think of it as your “working”. Marks will be deducted for failure to do so, or simple answers like “Go see the code yourself!” This applies for Questions 1 to 3.)

(a) (3 marks)

Defining a macro so that we can use it for all the multiplexers as the logic is the same.

The logic would be to check if condition is true(control signal is 1), then we would choose in1. If not,  
we would choose in2.

(b) (4 marks)

Check first 6 bits MSB (opcode)== 0 to see if its R-type instruction.

For each of the other components, create a bitmask for their specified bits and use bitwise OR to get the needed bits, then right shift accordingly so that we would just get those bits.

Since R-type and I / J type have different instruction formats, the bit mask and right shifts would be adjusted accordingly.

Q1 Total: \_\_\_\_\_\_\_\_\_ / 7

**Question 2.** (10 MARKS)

(a) (3 marks)

Using the opcode to generate the different control signals.

We can then find out the different control signals such as RegDst, ALUSrc, MemRead, MemWrite, Branch, MemtoReg and RegWrite based on the opcode, as different encoding types and instructions would lead to different signal outputs.

Based on the opcode, we can also generate the ALUOp signal. Non R-type instructions do not have funct codes, so we would use the opcode to generate this signal for lw,sw and beq instructions accordingly.

(b) (3 marks)

ALUControl will decode the functcode of R-type instructions to control the ALU. Based on the different funct code, we will return ALUControl signals for each of the different r-type instructions.

If they are Non R-type, we can decide what the output of ALUControl will be : if it is lw/sw (ALUop == 0), we would return 2 (ask the ALU to add). If it is a beq instruction(ALUop == 1) , we would return 6 (ask the alu to do subtraction)

(c) (4 marks)

Based on the different ALUControl signal, we would implement the operations accordingly. At the end, we would also check if result == 0 and store it in ALUiszero signal.

Q2 Total: \_\_\_\_\_\_\_\_\_ / 10

**Question 3.** (10 MARKS)

We start by declaring pointers to the various control signals.

We then move on to the decode stage, where we are able to get the decoding of the instruction.

This would then help us generate the control signals.

In the register file, we are able to get most of the registers required from the decoding.

WR requires a multiplexer to choose the correct write register by using the type of instruction.

We are then able to get the ALU operands: ALUop1 from RD1, and ALUop2 by using another multiplexer to choose between RD2 and the sign extended immediate.

For the PCSrc control signal, we set it to 1 when if it is both a branch instruction and also when ALU result is zero.

We would then calculate the branch target address using a multiplexer to choose between +4 (next instruction) or immediate\*4 + 4 (target adress).

In the memory stage, we would do the lw/sw operations using the Memory() method.

In the writeback stage, we would update WD by using a multiplexer to choose between the data from memory or the result calculated from the ALU.

The we would update the register file and the PC address.

Q3 Total: \_\_\_\_\_\_\_\_\_ / 10

**Part B**

**Question 4.** (10 MARKS)

You are expected to show working for each of the questions, not merely the final result. Marks may be deducted for failure to do so. Expand on the space as required.

4a. Draw your logic diagram neatly below. (2 marks)

4b. \_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_ (1 mark)

4c. \_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_ (1 mark)

4d. Prime implicants: \_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_ (1 mark)

4e. Essential prime implicants: \_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_ (1 mark)

4f. Simplified POS for \_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_ (2 marks)

4g. Simplified SOP for \_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_ (2 marks)

Q4 Total: \_\_\_\_\_\_\_\_\_ / 10

**Total Marks:** \_\_\_\_\_\_\_\_\_\_\_\_\_ / 40 (To be filled by TA only)

=== END OF PAPER ===